扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
以汽车为例:
public class Car: { private int weight; public int Weight { get { return weight; } set { weight = value; } } private string type; public string Type { get { return type; } set { type = value; } } } |
我们将类Car实现接口IComparable使其能够使用Array.Sort()。
代码如下:
public class Car:IComparable { private int weight; public int Weight { get { return weight; } set { weight = value; } } private string type; public string Type { get { return type; } set { type = value; } } IComparable 成员#region IComparable 成员 public int CompareTo(Car other) { if (this.weight == other.weight) return 0; if (this.weight > other.weight) return 1; return -1; } |
}实现该方法以后我们就可以直接使用如下代码来对cars进行排序了。
Car[] arr = new Car[] {car1,car2,car3 };
Array.Sort
不用担心我们只要使用一个最简单的Adapter模式就能解决这个问题下面我们来创建这个适配器:
public class ComparaCarAdapter : IComparer { IComparer 成员#region IComparer 成员 public int Compare(Car x, Car y) { return x.Type.CompareTo(y.Type); } |
}然后如此调用:
Array.Sort(arr,new ComparaCarAdapter());但是这样如果属性很多,会产生很多的类,怎么办呢。那么利用反射吧。将ComparaCarAdapter改造为: public class ComparaCarAdapter : IComparer { string _progName = ""; public ComparaCarAdapter(string progName) { _progName = progName; } IComparer 成员#region IComparer 成员 public int Compare(Car x, Car y) { Type t = typeof(Car); PropertyInfo pi = t.GetProperty(_progName); object xvalue = pi.GetValue(x, null); object yvalue = pi.GetValue(y, null); if (xvalue is string) { return ((string)xvalue).CompareTo((string)yvalue); } else { if (xvalue is int) return ((int)xvalue).CompareTo((int)yvalue); } throw new NotSupportedException(); } #endregion } |
濠电姷顣介埀顒€鍟块埀顒€缍婇幃妯诲緞閹邦剛鐣洪梺闈浥堥弲婊勬叏濠婂牊鍋ㄦい鏍ㄧ〒閹藉啴鏌熼悜鈺傛珚鐎规洘宀稿畷鍫曞煛閸屾粍娈搁梻浣筋嚃閸ㄤ即宕㈤弽顐ュС闁挎稑瀚崰鍡樸亜閵堝懎濮┑鈽嗗亝濠㈡ê螞濡ゅ懏鍋傛繛鍡樻尭鐎氬鏌嶈閸撶喎顕i渚婄矗濞撴埃鍋撻柣娑欐崌閺屾稑鈹戦崨顕呮▊缂備焦顨呴惌鍌炵嵁鎼淬劌鐒垫い鎺戝鐎氬銇勯弽銊ф噥缂佽妫濋弻鐔碱敇瑜嶉悘鑼磼鏉堛劎绠為柡灞芥喘閺佹劙宕熼鐘虫緰闂佽崵濮抽梽宥夊垂閽樺)锝夊礋椤栨稑娈滈梺纭呮硾椤洟鍩€椤掆偓閿曪妇妲愰弮鍫濈闁绘劕寮Δ鍛厸闁割偒鍋勯悘锕傛煕鐎n偆澧紒鍌涘笧閹瑰嫰鎼圭憴鍕靛晥闂備礁鎼€氱兘宕归柆宥呯;鐎广儱顦伴崕宥夋煕閺囥劌澧ù鐘趁湁闁挎繂妫楅埢鏇㈡煃瑜滈崜姘跺蓟閵娧勵偨闁绘劕顕埢鏇㈡倵閿濆倹娅囨い蹇涗憾閺屾洟宕遍鐔奉伓